package com.tjx.entity;

import com.baomidou.mybatisplus.annotation.IdType;
import com.baomidou.mybatisplus.annotation.TableField;
import com.baomidou.mybatisplus.annotation.TableId;
import com.baomidou.mybatisplus.annotation.TableName;
import java.math.BigDecimal;
import java.time.LocalDateTime;

import com.fasterxml.jackson.annotation.JsonFormat;
import lombok.Getter;
import lombok.Setter;

/**
 * <p>
 * 订单表
 * </p>
 *
 * @author tjx
 * @since 2025-10-29
 */
@Getter
@Setter
@TableName("`order`")
public class Order {

    /**
     * 自增主键
     */
    @TableId(value = "id", type = IdType.AUTO)
    private Integer id;

    /**
     * 订单编号（如ORD202510290001）
     */
    @TableField("order_no")
    private String orderNo;

    /**
     * 关联的用户业务ID（关联user表的user_id）
     */
    @TableField("user_id")
    private String userId;

    /**
     * 关联的套餐业务ID（关联package表的package_id）
     */
    @TableField("package_id")
    private String packageId;



    /**
     * 订单总金额（保留2位小数）
     */
    @TableField("total_amount")
    private BigDecimal totalAmount;

    /**
     * 订单状态（pending=待支付/paid=已支付/canceled=已取消）
     */
    @TableField("order_status")
    private String orderStatus;

    /**
     * 订单创建时间
     */
    @TableField("create_time")
    @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss", timezone = "GMT+8")
    private LocalDateTime createTime;

    /**
     * 支付完成时间
     */
    @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss", timezone = "GMT+8")
    @TableField("pay_time")
    private LocalDateTime payTime;

    /**
     * 逻辑删除（0=未删除，1=已删除）
     */
    @TableField("is_deleted")
    private Integer isDeleted;


}
